package com.alan.springbootbase.dao;

import org.springframework.data.jpa.repository.JpaRepository;
import org.springframework.data.jpa.repository.Modifying;
import org.springframework.data.jpa.repository.Query;
import org.springframework.data.repository.NoRepositoryBean;
import org.springframework.transaction.annotation.Transactional;

import java.util.List;

/**
 * @author Alan
 * @Description
 * @date 2021年02月20日 09:47
 */
@NoRepositoryBean
public interface BaseRepository<T, ID> extends JpaRepository<T,ID> {


    T findByUserName(String userName);


    /**
     * 查找ID且状态正常
     * @param id 主键ID
     * @param state 状态
     * @return 实体对象
     */
    public T findByIdAndState(ID id, Byte state);

    /**
     * 批量更新数据状态
     * #{#entityName} 实体类对象
     * @param state 状态
     * @param id ID列表
     * @return 更新数量
     */
    @Modifying
    @Transactional
    @Query("update #{#entityName} set state = ?1  where id in ?2 and status <> " + "11") //StatusConst.DELETE
    public Integer updateState(Byte state, List<ID> id);

}
